// 由于 webpack 是基于Node进行构建的，所以，webpack的配置文件中，任何合法的Node代码都是支持的
var path = require('path')
// 在内存中，根据指定的模板页面，生成一份内存中的首页，同时自动把打包好的bundle注入到页面底部
// 如果要配置插件，需要在导出的对象中，挂载一个 plugins 节点
var htmlWebpackPlugin = require('html-webpack-plugin');

const { VueLoaderPlugin } = require('vue-loader');


// 当以命令形式进行 webpack 或 webpack-dev-server 的时候，工具会发现，我们并没有提供要打包的 入口 和 出口 文件，此时，
// 它会检查项目根目录中的配置文件，并读取这个文件，就拿到了的导出的这个配置对象，然后根据这个对象，进行打包构建
module.exports = {
    entry:path.join(__dirname,'./src/main.js'), //入口文件
    output:{ //指定输出选项
        path:path.join(__dirname,'./dist'), //输出路径
        filename:'bundle.js' //指定输出文件的名称
    },
    plugins:[ //所有webpack插件的配置节点
        new htmlWebpackPlugin({
            template:path.join(__dirname,'./src/index.html'), //指定模板文件路径
            filename:'index.html' //设置生成的内存页面名称
        }),
        new VueLoaderPlugin()
    ],
    module:{ //配置所有第三方loader模块
        rules:[ //第三方模块的匹配规则
            { test:/\.css$/,use:['style-loader','css-loader']}, //处理css文件的loader
            { test:/\.less$/,use:['style-loader','css-loader','less-loader']}, //处理less文件的loader
            { test:/\.scss$/,use:['style-loader','css-loader','sass-loader']}, //处理scss文件的loader
            // limit 给定的值，是图片的大小，单位是 byte，如果我们引用的图片，大于或等于给定的 limit值，则不会被转为base64格式的字符串，如果图片小于给定的limit值，则会被转为base64的字符串
            { test:/\.(jpg|png|gif|bmp|jpeg)$/,use:'url-loader?limit=19737&name=[hash:8]-[name].[ext]'}, //处理图片路径的loader
            { test:/\.(ttf|eot|svg|woff|woff2)$/,use:'url-loader'}, //处理字体文件的loader
            { test:/\.js$/,use:'babel-loader',exclude:/node_modules/}, //配置Babel来转换高级的ES语法
            { test:/\.vue$/,use:'vue-loader'},  //出来.vue文件的loader
            // { test:/\.styl(us)?$/,use:['vue-style-loader','css-loader','stylus-loader']}
        ]
    },
    resolve:{
        alias:{ //修改 Vue 被导入时候包的路径
            "vue$":"vue/dist/vue.js"
        }
    }
}